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TECHNIQUE FOR ENABLING MESSAGING SYSTEMS TO USE ALTERNATIVE MESSAGE 

DELIVERY MECHANISMS 



The present invention relates to a computer system, and deals more 
particularly with a method, system, and computer program for enabling 
messaging systems to use alternative message delivery mechanisms. Use of 
this technique extends the real-time awareness aspect of instant messaging, 
so that messages may still be delivered from a sender using an instant 
messaging. system even though the intended receiver is not currently logged 
on to an instant messaging system (but is otherwise available) , or to 
deliver a message from a sender using a wireless messaging service via a 
mechanism for which a recipient has registered his availability. 

Instant messaging systems provide for instant, real-time 
communication between users who are connected to the system through an 
on-line or electronic networking environment. Examples of instant 
messaging systems include Yahoo!® Messenger, AOL Instant Messenger 5 ", and 
Sametime™. < "Yahoo!" is a registered trademark of Yahoo! Inc., "AOL 
Instant Messenger" is a service mark of America Online, Inc., and 
"Sametime" is a trademark of Lotus Development Corporation.) Such systems 
are becoming quite popular among users of networks such as the Internet, 
World Wide Web (hereinafter, "Web" ) , and internal intranets because they 
are easy to use and provide a simple way for one user to send a message to 
another user. 

Instant messaging systems provide real-time awareness of who is 
logged on. Typically, an instant messaging system (hereinafter, "IMS") 
user has an address book containing names or nicknames for those people 
with whom he communicates. The entries in this address book are used for 
selecting a message recipient. The IMS typically indicates, using a visual 
cue (such as different icons or different fonts) , which of the people are 
logged on to the system and which are not. For a message to be sent from a 
sending user to a receiving user, both users must be currently logged on to 
an IMS (which may be the same IMS, or a different IMS) . Otherwise, the 
system will not allow the sender to send his message. By ensuring that the 
receiver is available when a message is sent to him, the message can be 
delivered and presented to the recipient nearly instantly (depending on 
network delay) . 
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Instant messaging systems are distinguished from e-mail systems i 
that e-mail is not real-time in nature. E-mail systems merely accept 
electronic messages, and store them for delivery. There is no real-tinle 
awareness of whether the message recipient is currently logged on and cble 
to receive the message. Instead, the message is stored until such time as 
the. user logs on to the e-mail system and receives his waiting messages 

There may be a number of situations where the all-or-nothing appioach 
used by instant messaging systems is unwarranted. For example, it may 
happen that a recipient's status changes during an on-going communication. 
In this situation, a sender may be busily typing a message to the 
recipient, only to find out that the recipient has gone off-line - and the 
message is thus rejected by the IMS. Rather than completely discarding the 
sender's message, it would be preferable to provide an alternative 
technique for delivering the message. In many cases the sender's messalge 
is not time-critical, and a delivery mechanism other than the instant 
messaging system (such as sending the message by e-mail instead of witlJ the 
IMS) may be suitable to the sender. Selection of an alternative delivery 
mechanism is not an option of existing instant messaging systems. As yet 
another example, the recipient may be reachable by an alternative 
communication mechanism (such as a cellular phone, pager, etc.), even 
though he is not currently reachable by an IMS. Existing instant messaging 
systems do not provide users the ability to send messages to such 
recipients; instead, the sender must choose between not sending the message 
or physically changing to a different message -delivery system (such as 
leaving his computer to make a phone call to the recipient, and delivering 
the message in this manner) . Both options are inconvenient and inefficient 
for users. 

Wireless messaging system such as 2 -way paging systems and text 
messaging services using digital cellular telephone networks are also 
becoming pervasive. These wireless systems have some of the same 
characteristics of instant messaging systems. These wireless systems aLso 
have a number of drawbacks regarding message delivery. For example, if a 
particular user receives messages on a l-way pager, and another user sends 
a message to this person, the message will not be received if the pager is 
turned off. Or, if a user has a 2-way pager, he may not receive a sender's 
message in a timely manner. That is, if his pager is turned off when tne 
message is sent, he will not receive it until he later turns the pager oack 
on. Also, current wireless messaging systems do not interwork with instant 
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messaging systems, and do not provide the real-time awareness attribute 
that is a key benefit of an IMS. 

The present invention accordingly provides, in a first aspect, a 
computer program to, when loaded into a computer system and executed, 
enable an instant messaging system (IMS) to use alternative message 
delivery mechanisms, comprising: a message sender; one or more message 
recipients; a registry comprising an entry for one or more of said message 
recipients, wherein each of said entries comprises: (i) an alternative 
message delivery mechanism, and (ii) addressing information for said 
alternative; computer- readable program code means for receiving, from said 
message sender, a message to be delivered to a selected one of said message 
recipients; computer- readable program code means for determining, by said 
IMS, whether said selected one is currently logged on to said IMS or 
another IMS; computer- readable program code means for delivering said 
message to said selected one when said computer- readable program code means 
for determining has a positive result; and computer- readable program code 
means for forwarding said message on a particular alternative delivery 
mechanism associated with said recipient when said computer- readable 
program code means for determining has a negative result and when said 
particular mechanism is available. 

Preferably said computer- readable program code means for forwarding 
further comprises: computer- readable program code means for retrieving an 
25 associated entry from said registry using an identifier of said selected 

one; and computer- readable program code means for delivering said message 
to an address of said particular mechanism from said retrieved entry. 

Further preferably, said entry in said registry further comprises a 
30 constraint associated with said alternative message delivery mechanism, 

said constraint specifying a condition for use of said associated 
mechanism, and wherein said computer- readable program code means for 
forwarding further comprises: computer- readable program code means for 
verifying whether said condition from said retrieved entry is met; and 
35 computer -readable program code means for determining that said particular 

mechanism is available only when said condition is met. 
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A computer program according to the first aspect preferably further 
comprises computer- readable program code means for rejecting said message 
when said particular mechanism is not available. 
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Preferably, said computer- readable program code means for forwarding 
further comprises computer- readable program code means for notifying said 
sender of said particular alternative, and wherein said computer- readable 
program code means for forwarding further requires that said sender accspt 
said particular alternative. 

In a second aspect , the present invention provides a computer projram 
to, when loaded into a computer system and executed, enable an instant 
messaging system (IMS) to use alternative message delivery mechanisms, 
comprising: a message sender; one or more message recipients; 
a registry comprising an entry for one or more of said message recipients, 
wherein each of said entries comprises: (i) one or more alternative 
message delivery mechanisms, and <ii) addressing information for each ok 
said alternatives; computer- readable program code means for receiving, from 
said message sender, a message to be delivered to a selected one of saii 
message recipients; computer- readable program code means for determining, 
by said IMS, whether said selected one is currently logged on to said IMS 
or another IMS; computer- readable program code means for delivering saii 
message to said selected one when said computer- readable program code msans 
for determining has a positive result; and computer- readable program code 
means for forwarding said message on a particular alternative delivery 
mechanism associated with said recipient when said computer- readable 
program code means for determining has a negative result and when said 
particular mechanism is available. 

Preferably, said computer- readable program code means for forwarding 
further comprises: computer -readable program code means for retrieving m 
associated entry from said registry using an identifier of said selected 
one; and computer- readable program code means for delivering said message 
to an address of said particular mechanism from said retrieved entry. 

Preferably, said entry in said registry further comprises a 
constraint associated with each of said alternative message delivery 
mechanisms, each of said constraints specifying a condition for use of ;3aid 
associated mechanism, and wherein said computer -readable program code muans 
for forwarding further comprises: computer- readable program code means 
iteratively evaluating each of said conditions from said retrieved entri- 
until locating a match; and computer- readable program code means for us.ng 
said mechanism associated with said matched condition as said particular 
mechani sm. 



Preferably, the computer program of the second aspect further 
comprises computer- readable program code means for rejecting said message 
when none of said conditions are met. 

Preferably, the computer program of the second aspect further 
comprises computer -readable program code means for presenting available 
ones of said alternative delivery mechanisms to said sender when said 
computer- readable program code means for determining has said negative 
result; computer- readable program code means for enabling said sender to 
select from said presented ones; and wherein said computer- readable program 
code means for forwarding uses said selected one as said particular 
mechanism. 

Preferably said computer- readable program code means for forwarding 
further comprises: computer- readable program code means for selecting an 
available one of said registered alternative delivery mechanisms associated 
with said recipient; and computer-readable program code means for notifying 
said sender of said available one; and wherein said computer- readable 
program code means for forwarding further requires that said sender accept 
said available one. 

In a third aspect, the present invention provides a system in a 
computing environment for enabling an instant messaging system (IMS) to use 
alternative message delivery mechanisms, comprising: a message sender; one 
or more message recipients; a registry comprising an entry for one or more 
of said message recipients, wherein each of said entries comprises: (i) an 
alternative message delivery mechanism, and (ii) addressing information for 
said alternative; means for receiving, from said message sender, a message 
to be delivered to a selected one of said message recipients; means for 
determining, by said IMS, whether said selected one is currently logged on 
to said IMS or another IMS; means for delivering said message to said 
selected one when said means for determining has a positive result; and 
means for forwarding said message on a particular alternative delivery 
mechanism associated with said recipient when said means for determining 
has a negative result and when said particular mechanism is available. 

Preferably said means for forwarding further comprises: means for 
retrieving an associated entry from said registry using an identifier of 
said selected one; and means for delivering said message to an address of 
said particular mechanism from said retrieved entry. 
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Preferably, said entry in said registry further comprises a 
constraint associated with said alternative message delivery mechanism, 
said constraint specifying a condition for use of said associated 
mechanism, and wherein said means for forwarding further comprises: 
means for verifying whether said condition from said retrieved entry is 
met; and means for determining that said particular mechanism is available 
only when said condition is met. 

Preferably, there are provided means for rejecting said message when 
said particular mechanism is not available. 

Preferably, said means for forwarding further comprises means for 
notifying said sender of said particular alternative, and wherein said 
means for forwarding further requires that said sender accept said 
particular alternative. 

In a fourth aspect, the present invention provides a system in a 
computing environment for enabling an instant messaging system { IMS) to use 
alternative message delivery mechanisms, comprising: a message sender; pne 

r 

or more message recipients; a registry comprising an entry for one or m 
of said message recipients, wherein each of said entries comprises: (i 
one or more alternative message delivery mechanisms, and (ii) addressing 
information for each of said alternatives; means for receiving, from said 
message sender, a message to be delivered to a selected one of said mesfeage 
recipients; means for determining, by said IMS, whether said selected o: 
is currently logged on to said IMS or another IMS; means for delivering 
said message to said selected one when said means for determining has a 
positive result; and means for forwarding said message on a particular 
alternative delivery mechanism associated with said recipient when said 
means for determining has a negative result and when said particular 
mechanism is available. 

Preferably, said means for forwarding further comprises: means fo: 
retrieving an associated entry from said registry using an identifier o: 
said selected one; and means for delivering said message to an address 4>f 
said particular mechanism from said retrieved entry. 

Preferably, said entry in said registry further comprises a 
constraint associated with each of said alternative message delivery 
mechanisms, each of said constraints specifying a condition for use of ffcaid 
associated mechanism, and wherein said means for forwarding further 
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comprises: means for iteratively evaluating each of said conditions from 
said retrieved entry until locating a match; and means for using said 
mechanism associated with said matched condition as said particular 
mechanism. 

5 

The system according to the fourth aspect preferably further 
comprises means for rejecting said message when none of said conditions are 
met . 

10 The system according to the fourth aspect preferably further 

comprises means for presenting available ones of said alternative delivery 
mechanisms to said sender when said means for determining has said negative 
result; means for enabling said sender to select from said presented ones; 
and wherein said means for forwarding uses said selected one as said 

15 particular mechanism. 

The system according to the fourth aspect preferably further 
comprises means for receiving a multiple -recipient message from said 
sender, wherein said multiple- recipient message is to be delivered to more 

20 than one of said message recipients; and wherein: said means for 

determining whether said selected one is currently logged on determines 
whether each of said message recipients is currently logged on to said IMS; 
said means for delivering said message when said means for determining has 
said positive result delivers said message to each of said message 

25 recipients who is currently logged on; and when said means for determining 

has said negative result, said means for forwarding said message on said 
particular alternative delivery mechanism forwards said message to each of 
said message recipients who is not currently logged using an available 
mechanism associated with each of said not-logged-on message recipients. 

30 

The system according to the fourth aspect preferably further 
comprises means for selecting an available one of said registered 
alternative delivery mechanisms associated with said recipient; means for 
notifying said sender of said available one; and wherein said means for 
35 forwarding further requires that said sender accept said available one. 

In a fifth aspect the present invention provides a method for 
enabling an instant messaging system (IMS) to use alternative message 
delivery mechanisms in a computing environment, comprising the steps of: 
4 0 providing a registry comprising an entry for at least one of one or more 

message recipients, wherein each of said entries comprises: (i) an 
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alternative message delivery mechanism, and (ii) addressing information for 
said alternative; -receiving, from a message sender, a message to be 
delivered to a selected one of said message recipients; determining, by 
said IMS, whether said selected one is currently logged on to said IMS pr 
another IMS; delivering said message to said selected one when said 
determining step has a positive result; and forwarding said message on 
particular alternative delivery mechanism associated with said recipient 
when said determining step has a negative result and when said particular 
mechanism is available. 

Preferably, said forwarding step further comprises the steps of: 
retrieving an associated entry from said registry using an identifier of 
said selected one; and delivering said message to an address of said 
particular mechanism from said retrieved entry. 

Preferably, said entry in said registry further comprises a 
constraint associated with said alternative message delivery mechanism, 
said constraint specifying a condition for use of said associated 
mechanism, and wherein said forwarding step further comprises the steps of: 
verifying whether said condition from said retrieved entry is met; and 
determining that said particular mechanism is available only when said 
condition is met. 

The method preferably further comprises the step of rejecting said 
message when said particular mechanism is not available. 

Preferably, said forwarding step further comprises the step of 
notifying said sender of said particular alternative, and wherein said 
forwarding step further requires that said sender accept said particula 
alternative . 

In a sixth aspect, the present invention provides a method for 
enabling, an instant messaging system { IMS) to use alternative message 
delivery mechanisms in a computing environment, comprising the steps of 
providing a registry comprising an entry for at least one of one or mort; 
message recipients, wherein each of said entries comprises: (i) one or 
more alternative message delivery mechanisms, and (ii) addressing 
information for each of said alternatives; receiving, from a message 
sender, a message to be delivered to a selected one of said message 
recipients; determining, by said IMS, whether said selected one is 
currently logged on to said IMS or another IMS; delivering said message to 



said selected one when said determining step has a positive result; and 
forwarding said message on a particular alternative delivery mechanism 
associated with said recipient when said determining step has a negative 
result and when said particular mechanism is available. 

Preferably, said forwarding step further comprises the steps of: 
retrieving an associated entry from said registry using an identifier of 
said selected one; and delivering said message to an address of said 
particular mechanism from said retrieved entry. 

Preferably, said entry in said registry further comprises a 
constraint associated with each of said alternative message delivery 
mechanisms, each of said constraints specifying a condition for use of said 
associated mechanism, and wherein said forwarding step further comprises 
the steps of: iteratively evaluating each of said conditions from said 
retrieved entry until locating a match; and using said mechanism associated 
with said matched condition as said particular mechanism. 

The method preferably further comprises the step of rejecting said 
message when none of said conditions are met. 

The method preferably further comprises the steps of; presenting 
available ones of said alternative delivery mechanisms to said sender when 
said determining step has said negative result; enabling said sender to 
select from said presented ones; and wherein said forwarding step uses said 
selected one as said particular mechanism. 

The method preferably further comprises the step of: receiving a 
multiple -recipient message from said sender, wherein said 
multiple-recipient message is to be delivered to more than one of said 
message recipients; and wherein: said determining whether said selected one 
is currently logged on step determines whether each of said message 
recipients is currently logged on to said IMS; said delivering said message 
when said determining step has said positive result step delivers said 
message to each of said message recipients who is currently logged on; and 
when said determining step has said negative result, said forwarding said 
message on said particular alternative delivery mechanism step forwards 
said message to each of said message recipients who is not currently logged 
using an available mechanism associated with each of said not -logged -on 
message recipients . 
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Preferably, said forwarding step further comprises the steps of 
selecting an available one of said registered alternative delivery 
mechanisms associated with said recipient; and notifying said sender c 
said available one; and wherein said forwarding step further requires t 
said sender accept said available one. 



In a seventh aspect, the present invention provides a computer 
program to f when loaded and executed on a computer system, extend a 
wireless messaging system to enable use of registered message delivery 
mechanisms, comprising: a message sender; one or more message recipients; a 
registry comprising an entry for one or more of said message recipients 
wherein each of said entries comprises: (i) a registered message delivery 
mechanism, and (ii) addressing information for said mechanism; 
computer- readable program code means for receiving, from said message 
sender, a message to be delivered to a selected one of said message 
recipients; computer- readable program code means for determining, by sakd 
extended messaging system, whether said selected one is currently available 
on said registered mechanism; computer- readable program code means for 
delivering said message to said selected one on said available mechani 
when said computer- readable program code means for determining has a 
positive result; and computer- readable program code means for notifying 
said sender that said message cannot be delivered when said 
computer- readable program code means for determining has a negative result. 

In an eighth aspect, the present invention provides a system in a 
computing environment for extending a wireless messaging system to enabLe 
use of registered message delivery mechanisms, comprising: a message 
sender; one or more message recipients; a registry comprising an entry £or 
one or more of said message recipients, wherein each of said entries 
comprises: (i) one or more registered message delivery mechanisms, and 
(ii) addressing information for each of said mechanisms; means for 
receiving, from said message sender, a message to be delivered to. a 
selected one of said message recipients; means for determining, by said 
extended messaging system, whether said selected one is currently logged on 
to an IMS; means for delivering said message to said selected one using 
said IMS when said means for determining has a positive result; and means 
for forwarding said message on a particular registered delivery mechanii 
associated with said recipient when said means for determining has a 
negative result and when said particular mechanism is available. 



f 
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In a ninth aspect, the present invention provides a method for 
extending a wireless messaging system to enable use of registered message 
delivery mechanisms in a computing environment, comprising the steps of: 
providing a registry comprising an entry for at least one of one or more 
message recipients, wherein each of said entries comprises: (i) one or 
more message delivery mechanisms, and (ii) addressing information for each 
of said alternatives; receiving, from a message sender, a message to be 
delivered to a selected one of said message recipients; determining, by 
said extended wireless messaging system, whether said selected one is 
currently logged on to an IMS; delivering said message to said selected one 
using said IMS when said determining step has a positive result; and 
forwarding said message on a particular registered delivery mechanism 
associated with said recipient when said determining step has a negative 
result and when said particular mechanism is available. 

In a tenth aspect, the present invention provides a computer program 
to, when loaded and executed on a computer system, extend real-time 
awareness of users in a wireless messaging system, comprising: a first 
user; one or more other users; a registry comprising an entry for one or 
more of said other users, wherein each of said entries comprises: (i) a 
registered message delivery mechanism, and (ii) addressing information for 
said mechanism; computer- readable program code means for receiving, from 
said first user, a request for availability status information for a 
selected one of said other users; computer- readable program code means for 
determining, by said extended messaging system, whether said selected one 
is currently available on said registered mechanism; and computer- readable 
program code means for notifying said first user that said selected one is 
available when said computer -readable program code means for determining 
has a positive result. 

In an eleventh aspect, the present invention provides a system in a 
computing environment for extending real-time awareness of users in a 
wireless messaging system, comprising: a first user; one or more other 
users; a registry comprising an entry for one or more of said other users, 
wherein each of said entries comprises: (i) one or more registered message 
delivery mechanisms, and (ii) addressing information for each of said 
mechanisms; means for receiving, from said first user, a request for 
availability status information for a selected one of said other users; 
means for determining, by said extended messaging system, whether said 
selected one is currently available on any of said registered mechanisms; 
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and means for notifying said first user that said selected one is avaiJable 
when said means for determining has a positive result. 

In a twelfth aspect, the present invention provides method for 
extending real-time awareness of users in a wireless messaging system in a 
computing environment, comprising the steps of: providing a registry 
comprising an entry for at least one of one or more users of said wireless 
messaging system, wherein each of said entries comprises: (i) one or nore 
message delivery mechanisms, and (ii) addressing information for each cf 
said alternatives; receiving, from a first user, a request for availability 
status information for a selected one of said registered users; 
determining, by said extended wireless messaging system, whether said 
selected one is currently available on any of said registered mechanisns 
and notifying said first user that said selected one is available when said 
determining step has a positive result. A computer program to, when loaded 
into a computer system and executed, enable an instant messaging systerr 
(IMS) to use alternative message delivery mechanisms, comprising: a message 
sender; one or more message recipients; a registry comprising an entry for 
one or more of said message recipients, wherein each of said entries 
comprises: (i) an alternative message delivery mechanism, and (ii) 
addressing information for said alternative; computer- readable program [code 
means for receiving, from said message sender, a message to be delivered to 
a selected one of said message recipients; computer- readable program code 
means for determining, by said IMS, whether said selected one is currently 
logged on to said IMS or another IMS; computer- readable program code means 
for delivering said message to said selected one when said 
computer -readable program code means for determining has a positive reslult; 
and computer- readable program code means for forwarding said message on a 
particular alternative delivery mechanism associated with said recipient 
when said computer- readable program code means for determining has a 
negative result and when said particular mechanism is available. 

The present invention provides a system, method, and computer program 
for use in a computing environment, for enabling an instant messaging 
system (IMS) to use alternative message delivery mechanisms. In one 
embodiment, this technique comprises: providing a registry comprising kn 
entry for at least one of one or more message recipients, wherein each of 
the entries comprises: (i) an alternative message delivery mechanism, md 
(ii) addressing information for the alternative; receiving, from a message 
sender, a message to be delivered to a selected one of the message 
recipients; determining, by the IMS, whether the selected one is currently 
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logged on to the IMS or another IMS? delivering the message to the selected 
one when the determining has a positive result; and forwarding the message 
on a particular alternative delivery mechanism associated with the 
recipient when the determining has a negative result and when the 
particular mechanism is available. 

Accordingly, the present invention provides a technique by which 
messaging systems can be extended to provide their users with the ability 
to use alternative message delivery mechanisms, such that (i) in the case 
of an IMS -based sender, messages can be accepted for and delivered to a 
recipient even though he is not currently logged on to an IMS, and (ii) in 
the case of a sender using a wireless messaging system, the sender's 
message may be sent based on an awareness of how the recipient is currently 
reachable . 

The present invention advantageously provides a technique to extend 
the message delivery capabilities of messaging systems. 

The present invention advantageously provides this technique by 
enabling messages to be sent from instant messaging systems to users who 
are reachable through alternative delivery mechanisms, such that messages 
can be accepted for and delivered to a recipient even though he/she is not 
currently logged on to an IMS. 

The present invention advantageously provides this technique in a 
manner that operates according to user preferences. 

The present invention advantageously extends the real-time awareness 
aspect of wireless messaging systems by enabling a sender to determine a 
message recipient's availability. 

The present invention advantageously enables messages to be sent in a 
wireless environment based on alternative delivery mechanisms for which a 
recipient has registered his availability. 

The forwarding preferably further comprises: retrieving an 
associated entry from the registry using an identifier of the selected one; 
and delivering the message to an address of the particular mechanism from 
the retrieved entry. Each entry in the registry may further comprise a 
constraint associated with the alternative message delivery mechanism, this 
constraint specifying a condition for use of the associated mechanism, and 
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the forwarding may further comprise: verifying whether the condition flrom 
the retrieved entry is met; and determining that the particular mechanism 
is available only when the condition is met. The message may be rejected 
when the particular mechanism is not available. 

Or, the forwarding process may further comprise notifying the server 
of the particular alternative, wherein this forwarding process further 
requires that the sender accept the particular alternative. 

In another embodiment, this technique comprises: providing a 
registry comprising an entry for at least one of one or more message 
recipients, wherein each of the entries comprises: (i) one or more an 
alternative message delivery mechanisms, and (ii) addressing information 
for each of the alternatives; receiving, from a message sender, a message 
to be delivered to a selected one of the message recipients; determining 
by the IMS, whether the selected one is currently logged on to the IMS or 
another IMS; delivering the message to the selected one when the 
determining has a positive result; and forwarding the message on a 
particular alternative delivery mechanism associated with the recipient 
when the determining step has a negative result and when the particular 
mechanism is available. 

In this embodiment, the forwarding preferably further comprises: 
retrieving an associated entry from the registry using an identifier of the 
selected one; and delivering the message to an address of the particular 
mechanism from the retrieved entry. Each entry in the registry may further 
comprise a constraint associated with each of the alternative message 
delivery mechanisms, each of these constraints specifying a condition f^r 
use of the associated mechanism, and the forwarding step may further 
comprise: iteratively evaluating each of the conditions from the retrieved 
entry until locating a match; and using the mechanism associated with tie 
matched condition as the particular mechanism. The message may be rejepted 
when none of the conditions are met. 



The technique of this embodiment may further comprise: presentin 
available ones of the alternative delivery mechanisms to the sender whe: 
the determining has the negative result; enabling the sender to select 
the presented ones; and using, by the forwarding, the selected one as tie 
particular mechanism. 
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Alternatively in this embodiment, the forwarding process may further 
comprise selecting an available one of the registered alternative delivery 
mechanisms associated with the recipient, and notifying the sender of the 
available one, wherein the forwarding process further requires that the 
sender accept the available one. 

This embodiment may also further comprise: receiving a 
multiple -recipient message from the sender, wherein the multiple -recipient 
message is to be delivered to more than one of the message recipients; and 
wherein: the determining whether the selected one is currently logged on 
process determines whether each of the message recipients is currently 
logged on to the IMS; the delivering the message when the determining has 
the positive result process delivers the message to each of the message 
recipients who is currently logged on; and when the determining process has 
the negative result, the forwarding the message on the particular 
alternative delivery mechanism process forwards the message to each of the 
message recipients who, is not currently logged using an available mechanism 
associated with each of the not-logged-on message recipients. 

A preferred embodiment of the present invention will now be described 
with reference to the accompanying drawings, in which: 

Figure 1 is a block diagram of a computer workstation environment in 
which a preferred embodiment of the present invention may be practised; 

Figure 2 is a diagram of a networked computing environment in which a 
preferred embodiment of the present invention may be practised; 

Figure 3 depicts a sample registry of alternative message delivery 
mechanisms that may be used with a preferred embodiment of the present 
invention; 

Figure 4 shows an example message flow for a message delivered 
according to the extended IMS of a preferred embodiment of the present 
invention; and 

Figures 5A - 5G illustrate flow charts which set forth the logic 
which may be used to implement the preferred embodiments of the present 
invention. 
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Figure l illustrates a representative workstation hardware 
environment in which a preferred embodiment of the present invention maly be 
practised. The environment of Fig. 1 comprises a representative single 
user computer workstation 10, such as a personal computer, including 
related peripheral devices. The workstation 10 includes a microprocessor 
12 and a bus 14 employed to connect and enable communication between the 
microprocessor 12 and the components of the workstation 10 in accordance 
with known techniques. The workstation 10 typically includes a user 
interface adapter 16, which connects the microprocessor 12 via the bus 14 
to one or more interface devices, such as a keyboard 18, mouse 20, and/or 
other interface devices 22, which can be any user interface device, suc[h as. 
a touch sensitive screen, digitised entry pad, etc. The bus 14 also 
connects a display device 24, such as an LCD screen or monitor, to the 
microprocessor 12 via a display adapter 26. The bus 14 also connects tlhe 
microprocessor 12 to memory 28 and long-term storage 30 which can inclujde a 
hard drive, diskette drive, tape drive, etc. 

The workstation 10 may communicate with other computers or networks 
of computers, for example via a communications channel or modem 32. 
Alternatively, the workstation 10 may communicate using a wireless 
interface at 32, such as a CDPD (cellular digital packet data) card. T^e 
workstation 10 may be associated with such other computers in a local area 
network (LAN) or a wide area network (WAN) , or the workstation 10 can b- a 
client in a client/server arrangement with another computer, etc. All :>f 
these configurations, as well as the appropriate communications hardwar 
and software, are known in the art. 

Figure 2 illustrates a data processing network 4 0 in which a 
preferred embodiment of the present invention may be practised. The da:a 
processing network 40 may include a plurality of individual networks, s|ich 
as wireless network 42 and network 44, each of which may include a 
plurality of individual workstations 10. Additionally, as those skilled 
the art will appreciate, one or more LANs may be included (not shown) , 
where a LAN may comprise a plurality of intelligent workstations couple^ to 
a host processor. 

Still referring to Figure 2, the networks 42 and 44 may also include 
mainframe computers or servers, such as a gateway computer 4 6 or 
application server 47 (which may access a data repository 48) . A gatewiy 
computer 46 serves as a point of entry into each network 44. The gateway 
46 may be preferably coupled to another network 42 by means of a 
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communications link 50a. The gateway 46 may also be directly coupled to 
one or more workstations 10 using a communications link 50b, 50c. The 
gateway computer 46 may be implemented utilising an Enterprise Systems 
Architecture/3 70 available from the International Business Machines 
Corporation ("IBM"), an Enterprise Systems Architecture/390 computer, etc. 
Depending on the application, a midrange computer, such as an Application 
System/400 (also known as an AS/400) may be employed. ("Enterprise Systems 
Architecture/ 3 70" is a trademark of IBM; "Enterprise Systems 
Architecture/390", "Application System/400", and "AS/400" are registered 
trademarks of IBM.) 

The gateway computer 46 may also be coupled 49 to a storage device 
(such as data repository 48) . Further, the gateway 46 may be directly or 
indirectly coupled to one or more workstations 10. 

Those skilled in the art will appreciate that the gateway computer 46 
may be located a great geographic distance from the network 42, and 
similarly, the workstations 10 may be located a substantial distance from 
the networks 42 and 44. For example, the network 42 may be located in 
California, while the gateway 46 may be located in Texas, and one or more 
of the workstations 10 may be located in New York. The workstations 10 may 
connect to the wireless network 42 using a networking protocol such as the 
Transmission Control Protocol/ Internet Protocol ("TCP/IP"), AppleTalk®, or 
SNA over a number of alternative connection media, such as cellular phone, 
radio frequency networks, satellite networks, etc. ("AppleTalk" is a 
registered trademark of Apple Computer, Inc.) The wireless network 42 
preferably connects to the gateway 46 using a network connection 50a such 
as TCP or UDP (User Datagram Protocol) over IP, X.25, Frame Relay, ISDN 
(Integrated Services Digital Network), PSTN (Public Switched" Telephone 
Network), etc. The workstations 10 may alternatively connect directly to 
the gateway 46 using dial connections 50b or 50c. Further, the wireless 
network 42 and network 44 may connect to one or more other networks (not 
shown), in an analogous manner to that depicted in Fig. 2. 

Software programming code which embodies a preferred embodiment pf 
the present invention is typically accessed by the microprocessor 12 of the 
workstation 10 and server 4 7 from long-term storage media 30 of some type, 
such as a CD-ROM drive or hard drive. The software programming code may be 
embodied on any of a variety of known media for use with a data processing 
system, such as a diskette, hard drive, or CD-ROM. The code may be 
distributed on such media, or may be distributed to users from the memory 
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or storage of one computer system over a network of some type to other 
computer systems for use by users of such other systems. Alternatively 
the programming code may be embodied in the memory 28, and accessed by 
microprocessor 12 using the bus 14. The techniques and methods for 
embodying software programming code in memory, on physical media, and/c 
distributing software code via networks are well known and will not be 
further discussed herein. 
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A sender's computer, when using a preferred embodiment of the pre; 
invention, may be connected to a server embodying an IMS using a wired 
connection, or a wireless connection. Wired connections are those that 
physical media such as cables and telephone lines, whereas wireless 
connections use media such as satellite links, radio frequency waves, sli 
infrared waves. Many connection techniques can be used with these varic 
media, such as: using the computer's modem to establish a connection o 
a telephone line; using a LAN card such as Token Ring or Ethernet; usirjc 
cellular modem to establish a wireless connection; etc. The sender's 
computer may be any type of computer processor, including laptop, handheld 
or mobile computers; vehicle- mounted devices; desktop computers; mainf] 
computers; etc., having processing and communication capabilities. The 
remote server, similarly, can be one of any number of different types cJ 
computer which have processing and communication capabilities. These 
techniques are well known in the art, and the hardware devices and software 
which enable their use are readily available. Hereinafter, the sender' 
computer will be referred to equivalently as a "workstation", "machine", 
"device" , or "computer" , and use of any of these terms or the term "sei 
refers to any of the types of computing devices described above. 

In the preferred embodiments, the present invention is implemented as 
one or more modules (also referred to as code subroutines, or "objects" in 
object-oriented programming) of a computer software program (or programs) 
which provides instant messaging capabilities. The invention may be used 
with instant messaging systems in an Internet environment. Alternatively, 
the environment may be a corporate intranet, an extranet, or any other 
network environment. The program code of the preferred embodiment may be 
implemented as objects in an object-oriented programming language, or in a 
conventional procedural ly-oriented language, or in a mix of object-oriented 
and procedural language code. In the first preferred embodiment, the code 
of the present invention operates on the server. In the second, third, and! 
fifth preferred embodiments, the code operates partially on a server and 
partially on the sender's machine (for example, by using recipient 
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availability information received from a server to generate a graphical 
representation for local use by a sender, as will be described in detail 
below) . In the fourth preferred embodiment, the code operates primarily on 
a server, with message feedback information preferably presented on the 
sender's machine. 

Assume a user "S" wants to send a message "M" to a recipient W R" . 
Prior art instant messaging systems determine whether R is logged on to an 
IMS at the time, and present an awareness of this information to the sender 
S. If R is not logged on, the IMS prevents S from sending message M. A 
preferred embodiment of the present invention extends instant messaging 
systems to enable use of other forms of communications for message 
delivery, such that message sender S is able to send message M to recipient 
R even though that recipient is not currently logged on to an IMS. 

Alternatively, suppose sender S is using a wireless device, and does 
not have access to an IMS. Instead, S uses a wireless messaging service 
such as a paging network, digital cellular system, etc. As described 
earlier, S may send a message to R which R never receives, or which R 
receives in an untimely manner. A preferred embodiment of the present 
invention defines extensions for wireless messaging systems, where this 
extended system is referred to herein as an M Extended Messaging System" or 
"EMS" . This EMS is directed toward providing real-time recipient awareness 
to senders, and enabling use of alternative delivery mechanisms. This EMS 
enables the sender to either know in advance which delivery mechanism will 
be used, or to be notified after-the-fact as to what mechanism was used, as 
will be further described below. 

According to the first three embodiments of the present invention, a 
user of an IMS who chooses to receive messages through alternative delivery 
mechanisms registers the type of mechanism (s) - such as a pager, cell 
phone, screen phone, regular phone, personal digital assistant (PDA) , 
e-mail system, etc. - through which that user is available as an 
alternative. In addition to determining those users who are currently 
logged on to an IMS, these three embodiments of the present invention 
enable the IMS to extend its awareness of reachable users by consulting the 
registry (which may be, for example, a database or other storage facility) 
where the user's information is stored. Constraints or preferences may 
optionally be added to a registered alternative, such as specifying a 
limitation on days of the week and/or hours of the day when a particular 
alternative may be used. As an example of an alternative messaging 
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mechanism, suppose R has a 2 -way pager, and wants to be considered as 
"reachable" through this pager at times when he is not logged on to an IMS. 
R may then register that he can be reached by the pager, where information 
necessary for contacting R through his pager (such as his user 
identification, and the paging system to which he subscribes) is specified 
as part of the registered information. 

In the fourth and fifth embodiments, users similarly register 
alternative message delivery mechanisms through which they available, vfith 
or without constraints. Notably, these alternatives may include 
specification of some IMS through which a user can be reached, such thalt a 
message from a non-IMS -based sender may be received by a recipient usir.g 
his IMS . 

The preferred embodiments of the present invention will now be 
discussed in more detail with reference to Figs. 3 through 5. 

Fig. 3 depicts an illustration of alternative messaging mechanises 
which have been registered according to the preferred embodiments of the 
present invention. This example registry 300 contains entries 310, 320, 
330, 340 for four IMS users 311, 321, 331, 341. This registered 
information is depicted in tabular form for purposes of illustration, 
although it will be obvious to one of skill in the art that a number of 
alternative storage formats (such as entries in a directory or relational 
database) may be used without deviating from the inventive concepts 
disclosed herein. Further, a number of techniques for creating the 
registry may be used, which will be obvious to one of skill in the art. 
For ease of reference, the entries in this example registry will be 
discussed in terms of registration for use with an IMS-based sender, 
although this registry applies equivalently for the non-IMS-based EMS o[f 
the fourth and fifth embodiments. 

A user name 301 (or other suitable identifier, such as a unique user 
account number) for each user is used to store, and later locate, entri 
in the registry 300. An example of registering that a user is reachabl 
using a pager, and the contact information for the pager, is shown for 
311 at elements 312 and 313 of a mechanism registration 302 entry. Use|r 
321' s registration also specifies a pager device 322 and pager contact 
information 323. In a first optional aspect of the preferred embodiments, 
a particular IMS user may register more than one alternative messaging 
mechanism, as has been shown by additional entries for a cellular phone 314: 
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{for user 311) and a regular phone 324 (for user 321) . When a phone entry- 
is registered, the phone number by which the user can be reached is also 
registered (as shown at elements 315 and 325) . In this example registry, 
user 331 is only reachable by e-mail as an alternative to an IMS, as 
indicated by the single mechanism registration entry specifying e-mail 
(element 332) and an e-mail address (element 333) . User 341 is also 
reachable by a single alternative, shown at 342 as a PalmPilot® device, 
where this user is reachable with the registered address shown at 343. 
("PalmPilot" is a registered trademark of 3Com Corporation.) 

In a second optional aspect of the preferred embodiments, constraints 
may be used to limit the use of an alternative mechanism. For example, 
user R may not wish to receive messages on his pager (or other somewhat 
disruptive devices such as regular telephones, screen phones, or cell 
phones) between the hours of 11 p.m. and 8 a.m. For this second optional 
aspect, the availability of a user at a particular registered alternative 
may be indicated in the registry in a number of ways. Preferably, each 
registered mechanism entry 302 has an associated constraint or status 303. 
The value in this status entry 303 may be specified using one of several 
approaches. In a first approach, the registered status entry 303 
associated with the alternative may be left unspecified to indicate the 
absence of any constraints (i.e. that this alternative is always 
available) . Or, when constraints are to be applied with this first 
approach, they may be interpreted in either a positive or a negative sense 
(that is, a specification of when this alternative is available or when it 
is unavailable, respectively). The example registry 300 in Fig. 3 
illustrates another approach, where each status entry 303 is comprised of 
two parts. The first part is a status indication, which is used to 
explicitly specify the interpretation of the constraint. This indication 
has the value "In" for registered mechanism entries 312, 314, 322, 332, and 
342 (as shown at elements 316, 318, 326, 336, and 346), and has the value 
"Out" for registration entry 324 (as shown at element 328) . 
(Alternatively, other values such as "Available" and "Unavailable", or 
equivalent representations thereof such as a binary flag having the values 
1 and 0, may also be used.) The second part specifies a condition, such as 
a time period or days of the week, which constrains availability of the 
mechanism. Thus, status entry 316, 317 indicates that user 311 can be 
reached by his pager 24 hours per day, while he can only be reached by his 
cellular phone between the hours of 9 and 5 (status entry 318, 319) . User 
321' s pager is only an alternative between 9 and 5, whereas his regular 
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phone is an alternative except during the hours between 8 and 6 (see 
elements 326, 327 and 328, 329). 

In a third optional aspect of the embodiments of the present 
invention, it may be desirable to allow multiple constraints to be 
specified for one mechanism, such as various periods throughout the day 
when the alternative mechanism is available. In this case, an appropriate 
technique such as specifying Boolean operators within a single registration 
status 3 03 or using multiple registration entries 302 may be used. 
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The technique with which evaluation of the constraint entries 3 03 
performed does not form part of the present invention. If the evaluati 
is performed in such a way that the first satisfied constraint is retui 
then each of the entries in the registry for a particular user should fc 
specified in order of most restrictive to least restrictive. For examr. 
user 311' s cellular phone entry 314 , 315 should be specified before his 
pager entry 312, 313, to prevent the pager entry from always being 
selected. 



Fig. 4 shows a high-level example of the message flows that occur 
with the IMS extension of a preferred embodiment of the present invention. 
These flows are also applicable for the non- IMS -based sender scenario, 
where the element 403 is replaced by a wireless messaging system extended 
according to the fourth and fifth embodiments (i.e. an "EMS"). Sender 
401 wishes to send an instant message 402a to a particular recipient, wtho 
for this example is the user "Dave Smith" 311. Assume that this user i 
not logged on to an IMS at the time. In the prior art, the IMS would 
reject the message 402a, leaving sender 401 the options of not sending the 
message or finding some alternative way to contact user 311. According to 
a preferred embodiment of the present invention, however, the extended IMS 
403 receives the message 402a, and searches for alternative mechanisms for 
delivering the message 402a to user 311. The preferred embodiments of the 
technique with which the search for alternative mechanisms is performed is 
discussed below, with reference to Fig. 5. Further assume that the 
extended IMS 403 locates user 311' s entries in registry 300, indicating 
that user 311 can be reached by pager 24 hours per day (elements 312, 313, 
316, 317) or by cellular phone between the hours of 9 and 5 (elements 314, 
315, 318, 319), and that the current time of day is 8 p.m. Thus, the entry 
registered for the pager will be used. The extended IMS 403 will forward 
message 402b to user 311' s pager 405, using the registered address 
information 313. 
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As indicated at 404 , the message 402b may optionally pass through a 
transformation engine before being delivered. This would be the case, for 
example, where the textual message 402a created by sender 4 01 is to be 
delivered through a non-textual mechanism such as a regular phone. 
Extended IMS 403 then forwards the message 4 02b through a text -to- speech 
transformation process 404 {such as a commercially- available voice 
synthesiser) on its way 402c to the destination device. When support for 
transformation engines of this type is provided in an implementation of a 
preferred embodiment of the present invention, selection of the 
transformation engine to be used for a particular registered mechanism is 
preferably performed by consulting a previously- stored look- up table (or 
other stored information, such as an association coded directly into the 
extended IMS implementation or EMS implementation) whereby the mechanism 
type is associated with the transformation engine to be used. 

Message flow 406 indicates that the sender 401 will preferably be 
informed when an alternative message delivery mechanism, other than the 
instant delivery of the IMS, has been used. Further, this message 406 will 
preferably notify the sender as to which alternative mechanism was used. 

Fig. 5A, below, describes the logic used for implementing this 
technique for the extended IMS of the first preferred embodiment. The 
fourth preferred embodiment is similar to the first, with a significant 
difference being that the sender is not using an IMS. The sender's message 
is received at the EMS, and forwarded by the EMS if the recipient is 
reachable on a registered mechanism (including an IMS). Figs. 5F1 and 5F2 
describe the logic used for implementing this fourth preferred embodiment. 

In a second preferred embodiment, instead of programmatic ally 
selecting an alternative mechanism from the registry 300, the extended IMS 
4 03 may determine the available alternative delivery mechanisms, and 
present them to the sender 401. Appropriate icons or text may be used to 
represent the choices, such as a graphical representation of a regular 
phone or pager, etc. In this embodiment, the sender then has the option of 
selecting one of the alternatives that he finds most suitable, or deciding 
to cancel the message. As will be obvious, additional message flows 
between the sender 401 and extended IMS 403 occur for this embodiment. 
This embodiment requires software that is specific to the implementation of 
the present invention to be residing on the sender's device, for: 
receiving a set of alternative mechanisms from the extended IMS; 
presentation of these alternatives to the sender; allowing the sender to 
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select from the alternatives; and forwarding the selected choice to tht^ 
extended IMS. (This embodiment is described below in terms of how Fig 
and 5C modify the logic of Fig. 5A.) 
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In a third preferred embodiment, instead of allowing the sender tto 
choose from the recipient's available alternative mechanisms (as in th<; 
second preferred embodiment) , the extended IMS 403 determines which 
alternative would be used for a particular message delivery, and notif 
the sender that this alternative will be used. The sender may then 
between having the message delivered using this mechanism, or not send 
the message. As described for the second preferred embodiment, appropi 
icons or text may be used to represent the alternative mechanism to th« 
sender, and additional message flows between the sender 401 and extended 
IMS 403 occur for this embodiment. This third embodiment also requires 
software that is specific to the implementation of the present invent 
be residing on the sender's device, for: receiving information identi 
a particular alternative mechanism from the extended IMS; presentation 
this alternative to the sender; allowing the sender to choose to use tt 
alternative; and subsequently forwarding the message to the extended 
(This third embodiment is described below in terms of how Fig. 5D modii 
the logic of Fig. 5A, and also makes use of Fig. 5B.) 

In the fifth preferred embodiment, a sender using a wireless 
messaging system may wish to know if and how a recipient is reachable 
before sending a message (or deciding whether to send a message) to this 
recipient. The sender issues a status request for a recipient, for e 
by clicking on a graphical icon associated with the recipient on the 
sender's display. This request is then received at the EMS, which 
determines the recipient's availability and returns that information tc 
sender. (This fifth embodiment is described below with reference to 
5G.) 

Fig. 5A depicts a flow chart which sets for the logic that may be 
used to implement the first preferred embodiment of the present i] 
The logic of this flow chart represents the processing performed by the 
extended IMS of the present invention for each incoming message, using 
programmatic selection of an alternative message delivery mechanism, 
process begins at Block 50 0, where a message is received from a sender. 
Block 505, a test is made to determine whether the target message rec 
is currently logged on to an IMS. If this test has a positive result, 
the message is sent at Block 510 (as in the prior art) f and the process 
Fig. 5 ends. Otherwise, control transfers to Block 515. 
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At Block 515, the registry of alternative mechanisms is checked to 
see if any entries have been registered for this recipient. As stated 
previously, the recipient's name or other identifier is preferably used to 
access the registry. Block 520 then checks to see if any registered 
alternatives were located for this user. If this test has a negative 
result, then the message cannot be sent. An error message or other 
notification will be returned to the sender by Block 525, after which the 
processing of Fig. 5 ends. Otherwise, control transfers to Block 530. 

Block 530 begins an iterative process through the one or more 
registered alternative mechanisms, checking to see if any constraints 
registered with a particular mechanism have been met. In the first 
preferred embodiment (as well as the third preferred embodiment, to be 
discussed below with reference to Fig. 5D) , this iterative checking process 
ends with the first successful match. (Fig. 5C presents the second 
preferred embodiment discussed above, where each available alternative is 
presented to the user.) If a successful match is found at Block 530, 
control transfers to Block 535. Block 535 then asks whether any 
transformations (such as text to voice, as discussed above) need to be 
performed before delivering this message using the alternative delivery 
mechanism. If so, then control transfers to Block 540 where the 
appropriate transformation engine is invoked. When the message has been 
transformed, or when Block 535 has a negative result, control reaches Block 
545 where the message is delivered to the recipient using the selected 
alternative mechanism. The processing of Fig. 5 then ends. 

When the constraint being checked at Block 530 was' not met, control 
reaches Block 550. Here, a test is made to see if the alternative 
mechanism being evaluated was the last registered alternative. If so, then 
the message cannot be delivered, and an error message or other notification 
will be returned to the sender at Block 555 (or, equivalently, by 
transferring control to Block 525) . Otherwise, when there are more 
constraints to evaluate, control returns from Block 550 to Block 530. The 
evaluation process will then continue until either a constraint is 
successfully matched, or no more registration entries exist. 

Note that the logic depicted in Fig. 5 supports the aspects which 
were described above as being optional for the preferred embodiments. It 
will be obvious to one of ordinary skill in the art how the logic of Fig. 5 
can be modified to remove support for one or more optional aspects, should 
that be desired in a particular implementation. Further note that the 
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logic of Fig. 5 is directed toward delivering a message to a single 
recipient. It may be desirable to allow messages to be delivered to 
multiple recipients, each of which may use a different alternative deli 
mechanism. It will be obvious how this logic may be modified to suppoi 
message delivery to more than one recipient. 
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Figs. 5B and 5C depict the logic that may be used in the second 
preferred embodiment, to augment the logic of Fig. 5A in order to provide 
sender control over which alternative message delivery mechanism is use 
The logic of Fig. 5B would be inserted between Blocks 505 and 515 of Fig 
5A, such that after receiving a message {Block 505), a check is made hy 
Block 570 to see if this message specifies the sender's selection of 
mechanisms. If it does, then control transfers to Block 535' to determ 
how to send the message using this mechanism. {The processing of Blocks 
535', 540, and 545' is identical to that described for Blocks 535, 540, 
545 of Fig. 5A.) Otherwise, it can be assumed that this is the sender' 
original message (i.e. the extended IMS has not yet notified the sender 
that an alternative mechanism is needed) , and control will continue to 
Block 515 to begin determination of the available choices. Fig. 5C depicts 
the logic used in this second embodiment to replace Blocks 530 through 
of Fig. 5A. The processing of Block 530' is identical to that of Block 
of Fig. 5A, which determines whether the constraint for the alternative 
being evaluated is met, except for the transfer of control upon detecting 
positive result. When Block 530' has a positive result (i.e. the 
constraint is met) , then Block 580 adds this mechanism to a list of 
available choices. The information in the list comprises the mechanism 
type, and may also include the registered address information and 
constraint information for recipient R. Control then transfers to Bloc 
550', which functions in the same manner previously described for Block 
of Fig. 5A, except for the processing of the positive result case (i.e. 
when the last registered entry for the target recipient has been 
evaluated) . When the result is positive, Block 585 returns the list of 
available choices (created by one or more executions of Block 580) to the 
sender. (As stated previously, the sender may select from this list, aijid 
then transmit the message and his chosen mechanism to the extended IMS; 
this transmission will be processed according to the description of Bio 
570, above.) Processing of the logic in Fig. 5C then ends. 



Fig. 5D, along with Fig. 5B, depicts the logic that may be used ii|i a 
third preferred embodiment to augment the logic of Fig. 5A in order to 
provide a sender with information that an alternative mechanism will be 
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used for a recipient, enabling the sender to choose whether to have the 
message delivered using that mechanism. As discussed above with reference 
to the second preferred embodiment, the logic of Pig. 5B would be inserted 
between Blocks 505 and 515 of Fig. 5A, to determine whether the incoming 
5 message specifies the alternative mechanism. Fig. 5B functions in the same 

manner for this third embodiment as has been described for the second 
embodiment . 

Fig. 5D depicts the logic used in this third embodiment to replace 
10 Blocks 530 through 555 of Fig. 5A. The processing of Block 530'' is 

identical to that of Block 530 of Fig. 5A, which determines whether the 
constraint for the alternative being evaluated is met, except for the 
transfer of control upon detecting a positive result. When Block 530'' has 
a positive result (i.e. the constraint is met), then Block 590 returns an 
15 indication to the sender that this mechanism will be used if the message is 

sent. As described for the second embodiment, the information sent to the 
sender regarding an alternative comprises the mechanism type, and may also 
include the registered address information and constraint information for 
recipient R. After sending this information at Block 590, the processing 
20 of Fig. 5D ends. When Block 530' 1 has a negative result, the further 

processing of Blocks 550'' and 555' occurs in a manner identical to that 
described earlier for Blocks 550 and 555. Processing of the logic in Fig. 
5D then ends . 

25 The processing of Figs. 5A through 5D and 5F uses a message-driven 

approach to determining the availability of a particular recipient R. In 
an alternative approach, it may be preferable to determine availability of 
all the users {or selected users) typically represented on a sender's IMS 
display (i.e. all the users listed in the address book or other directory 

30 used for this sender's IMS), and refresh the user's display so that the 

availability status is displayed without regard to whether the sender is 
creating (or has created) a message to be delivered. The logic with which 
this alternative approach may be implemented for an IMS environment is 
depicted in Fig. 5E; Fig. 5G depicts an analogous capability for a 

35 non- IMS-based sender using a wireless messaging system. (Note that Fig. 5E 

depicts only the logic used to obtain the display -re freshing information; 
the logic with which an incoming message is handled at the IMS preferably 
uses the first preferred embodiment as depicted in Fig. 5A. Similarly, 
Fig. 5G depicts only the logic for retrieving a recipient's availability 

4 0 information; if a message is sent to this recipient, it is preferably 

handled according to the logic of Fig. 5F.) 
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The processing of Fig. 5E may be initiated in a timer-driven manr.er 
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or in an event- driven manner. When a timer is used, it will preferably be ; 
set to a relatively short period, to enable the display to be refreshed 
often enough to detect availability changes in near real-time. When tt< 
initiation is event-driven, the events will preferably be changes in tli 
result of evaluating constraints for the registered users (such as pass; 
from a time period when a particular recipient has no available alternative- 
delivery mechanism into a time period where a constraint is met for this 
recipient's registered alternative mechanisms, thus making the recipient 
now reachable) . Alternatively, the event may be receipt of a 
sender- initiated request for availability information. 

The processing of Fig. 5E will preferably be repeated for each 
registered user. The processing for an individual user, referred to as 
recipient R, begins at Block 605 which checks to see if this recipient 
currently logged on. If so, then Block 610 indicates that this user wi 
be displayed to the sender as reachable using an IMS {in the same manne|r 
used in existing instant messaging systems) . Otherwise, Block 615 
retrieves the entries for R from the registry. If none were located, t^ien 
Block 62 0 has a negative result, and Block 625 indicates that this 
recipient will be displayed to the sender as unreachable. If entries w^re 
located for R, then processing continues at Block 630. Blocks 630 and 
represent an iterative evaluation of the registered constraints, as in 
5A, that ends when (i) a matching constraint is found (after which contirol 
transfers to Block 635), or (ii) the last constraint has been evaluated 
without locating a match (transferring control to Block 645) . If control 
reaches Block 635, the sender's display will indicate (using, e.g., an 
appropriate icon and perhaps additional information as previously 
discussed) the mechanism through which the recipient is currently 
reachable. If control reaches Block 645, on the other hand, the sender 
display will indicate that this recipient is not reachable. 

Figs. 5F1 and 5F2 depict a programmatic delivery mechanism select. L on 
initiated on an EMS in response to receiving a message from a sender. (By 
inspection, it can be seen that the flowchart presented in these figure:* is 
very similar to that of Fig. 5A. Thus, the following description of Fi<j. 
5F omits the detailed processing description, such as explanation by use of 
examples, for blocks which have analogous counterparts in Fig. 5A.) 

Upon receiving an incoming message at Block 660 of Fig. 5F1, the 
process immediately consults the registry (Block 665) . If there are no 
registered entries at all for this recipient, then Block 680 notifies the 
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sender that the message could not be delivered. Otherwise, when registered 
entries were located, Block 685 asks whether one of them was an IMS. This 
mechanism is treated separately from other mechanisms by the logic of Fig. 
5F1 to emphasise a preference for sending the message through an "instant" 
mechanism when one is available. (Note that this preference is optional, 
and that a registered IMS could alternatively be handled in the same manner 
as other registered mechanisms by omitting Blocks 685 through 700.) If an 
IMS is registered, Block 690 checks to see if the recipient is currently 
logged on to this IMS. If not, control returns to Block 705; otherwise, 
the message is delivered using the IMS (Block 695) and the sender is so 
informed by returning an indication at Block 700. 

Blocks 705, 720 and 725 perform an iterative process of evaluating 
registered entries, as has been described. Block 710 presents an optional 
aspect whereby, upon determining that R is not currently reaching using any 
of his registered alternatives, it may be desirable to determine - from the 
registry - whether R is reachable at a later time. For example, a sender 
may be trying to contact a service technician or delivery person. Rather 
than simply inform the sender that he cannot currently reach this 
recipient, Block 710 provides for conveying when the sender might "try 
again" . This process comprises evaluating the constraints for R' s 
registered entries, obtaining one or more times (and mechanisms) with which 
R may subsequently be available. Block 715 notifies the sender that his 
message could not be sent at this time, and when Block 710 is implemented, 
further notifies the sender of R' s subsequent availability status. 

When a matching constraint is found in Block 725, control transfers 
to Block 730 of Fig. 5F2 . Blocks 730 and 735 indicate that optional 
transformations may be performed, as previously described. The message is 
delivered on the selected mechanism at Block 740. If this delivery service 
provides delivery confirmation (Block 745) , the EMS may optionally choose 
to await confirmation (Block 750) before notifying the sender of the 
message delivery (and, preferably, the mechanism used) at Block 755. 

Fig. 5G depicts the logic with which a sender using a wireless 
messaging service can request the EMS of the present invention to provide 
the sender with availability information for a user (or perhaps users) . 
This technique is similar to that depicted in Fig. 5E. 

Upon receiving the status request (Block 760) , the registry is 
consulted (Block 765) . As in Fig. 5F, if there is no registered 
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information for user W R" , the sender will be informed that R is unreact 
(Block 775). Otherwise, Blocks 780 and 785 determine if R is currently 
reachable by a registered IMS; if so, this information is conveyed to t 
user at Block 790. (As discussed with reference to Fig. 5F1, the 
preferential handling for an IMS at Blocks 780 through 790 is optional, 
could be omitted.) Blocks 795, 805, and 810 iteratively loop through t 
registered entries, as has been described, to determine if a registered 
mechanism is currently available. If not, then optionally, the proces 
of Block 710' (as described for Block 710 of Fig. 5F1) may be performed 
prior to returning an indication to the sender (Block 800) that R is 
currently unreachable (where the optional Block 710' processing provide 
for also informing the sender when R may be available later) . When a 
matching constraint was found, the sender is notified of this mechanism; 
Block 815. 
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The description of the present invention discloses advantageous 
techniques for extending messaging systems. Thus, use of the embodiment 
of the present invention enables an IMS -based sender's message to be 
delivered even though the intended receiver is not currently logged on |to 
an instant messaging system, provided that an alternative messaging 
mechanism for the recipient is registered (and any constraints for this 
alternative are satisfied) . Use of the present invention also enables 
sender using a wireless messaging service to have the extended real-tim 
awareness that is an aspect of instant messaging systems, and enables 
25 messages to be sent from this sender based on alternative delivery 

mechanisms for which a recipient has registered his availability. 
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CLAIMS 



1. A computer program to, when loaded into a computer system and 
executed, enable an instant messaging system (IMS) to use alternative 
message delivery mechanisms, comprising: 

a message sender; 

one or more message recipients; 

a registry comprising an entry for one or more of said message 
recipients, wherein each of said entries comprises: (i) an alternative 
message delivery mechanism, and (ii) addressing information for said 
alternative; 

computer- readable program code means for receiving, from said message 
sender, a message to be delivered to a selected one of said message 
recipients; 

computer- readable program code means for determining, by said IMS, 
whether said selected one is currently logged on to said IMS or another 
IMS; 

computer- readable program code means for delivering said message to 
said selected one when said computer- readable program code means for 
determining has a positive result; and 

computer- readable program code means for forwarding said message on a 
particular alternative delivery mechanism associated with said recipient 
when said computer- readable program code means for determining has a 
negative result and when said particular mechanism is available. 

2. The computer program according to Claim 1, wherein said 
computer- readable program code means for forwarding further comprises: 

computer -readable program code means for retrieving an associated 
entry from said registry using an identifier of said selected one; and 

computer- readable program code means for delivering said message to 
an address of said particular mechanism from said retrieved entry. 
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3. The computer program according to Claim 2, wherein said entry in said 
registry further comprises a constraint associated with said alternative 
message delivery mechanism, said constraint specifying a condition for use 
of said associated mechanism, and wherein said computer -readable prograjm 
code means for forwarding further comprises: 

computer- readable program code means for verifying whether said 
condition from said retrieved entry is met; and 

computer-readable program code means for determining that said 
particular mechanism is available only when said condition is met. 

4. The computer program according to Claim 3, further comprising 
computer- readable program code means for rejecting said message when said 
particular mechanism is not available. 

5. The computer program according to Claim 1, wherein said 
computer- readable program code means for forwarding further comprises 
computer- readable program code means for notifying said sender of said 
particular alternative, and wherein said computer- readable program code 
means for. forwarding further requires that said sender accept said 
particular alternative. 

6. A computer program to, when loaded into a computer system and 
executed, enable an instant messaging system (IMS) to use alternative 
message delivery mechanisms, comprising: 



a message sender; 

one or more message recipients; 



a registry comprising an entry for one or more of said message 
recipients, wherein each of said entries comprises: (i) one or more 
alternative message delivery mechanisms, and (ii) addressing information 
for each of said alternatives; 



computer- readable program code means for receiving, from said message 
sender, a message to be delivered to a selected one of said message 
recipients ; 



computer- readable program code means for determining, by said IMS, 
whether said selected one is currently logged on to said IMS or another 
IMS; 

computer- readable program code means for delivering said message to 
said selected one when said computer -readable program code means for 
determining has a positive result; and 

computer- readable program code means for forwarding said message on a 
particular alternative delivery mechanism associated with said recipient 
when said computer- readable program code means for determining has a 
negative result and when said particular mechanism is available. 

7. The computer program according to Claim 6, wherein said 
computer- readable program code means for forwarding further comprises: 

computer- readable program code means for retrieving an associated 
entry from said registry using an identifier of said selected one; and 

computer- readable program code means for delivering said message to 
an address of said particular mechanism from said retrieved entry. 

8. The computer program according to Claim 7, wherein said entry in said 
registry further comprises a constraint associated with each of said 
alternative message delivery mechanisms, each of said constraints 
specifying a condition for use of said associated mechanism, and wherein 
said computer- readable program code means for forwarding further comprises: 

computer- readable program code means for iteratively evaluating each 
of said conditions from said retrieved entry until locating a match; and 

computer- readable program code means for using said mechanism 
associated with said matched condition as said particular mechanism. 

9. The computer program according to Claim 8, further comprising 
computer- readable program code means for rejecting said message when none 
of said conditions are met. 

10. The computer program according to Claim 6, further comprising: 
computer- readable program code means for presenting available ones of 

said alternative delivery mechanisms to said sender when said 
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computer- readable program code means for determining has said negative 
results- 
computer- readable program code means for enabling said sender to 
select from said presented ones; and 



wherein said computer- readable program code means for forwarding |uses 
said selected one as said particular mechanism. 

11. The computer program according to Claim 6, wherein said 
computer -readable program code means for forwarding further comprises: 

computer- readable program code means for selecting an available < 
of said registered alternative delivery mechanisms associated with said 
recipient; and 

computer- readable program code means for notifying said sender of 
said available one; and wherein said computer- readable program code means 
for forwarding further requires that said sender accept said available bne. 

12. A system in a computing environment for enabling an instant messaging 
system { IMS) to use alternative message delivery mechanisms, comprising: 

a message sender; 

one or more message recipients; 

a registry comprising an entry for one or more of said message 
recipients, wherein each of said entries comprises: (i) an alternative 
message delivery mechanism, and (ii) addressing information for said 
alternative; 

means for receiving, from said message sender, a message to be 
delivered to a selected one of said message recipients; 

means for determining, by said IMS , whether said selected one is 
currently logged on to said IMS or another IMS; 



means for delivering said message to said selected one when said 
means for determining has a positive result; and 
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means for forwarding said message on a particular alternative 
delivery mechanism associated with said recipient when said means for 
determining has a negative result and when said particular mechanism is 
available. 

13. The system according to Claim 12, wherein said means for forwarding 
further comprises: 

means for retrieving an associated entry from said registry using an 
identifier of said selected one; and. 

means for delivering said message to an address of said particular 
mechanism from said retrieved entry. 

14. The system according to Claim 13, wherein said entry in said registry 
further comprises a constraint associated with .said alternative message 
delivery mechanism, said constraint specifying a condition for use of said 
associated mechanism, and wherein said means for forwarding further 
comprises : 

means for verifying whether said condition from said retrieved entry 
is met; and 

means for determining that said particular mechanism is available 
only when said condition is met. 

15. The system according to Claim 13, further comprising means for 
rejecting said message when said particular mechanism is not available. 

16. The system according to Claim 12, wherein said means for forwarding 
further comprises means for notifying said sender of said particular 
alternative, and wherein said means for forwarding further requires that 
said sender accept said particular alternative. 

17. A system in a computing environment for enabling an instant messaging 
system (IMS) to use alternative message delivery mechanisms, comprising: 

a message sender; 

one or more message recipients; 



a registry comprising an entry for one or more of said message 
recipients, wherein each of said entries comprises: <i) one or more 
alternative message delivery mechanisms, and (ii) addressing information 
for each of said alternatives; 

means for receiving, from said message sender, a message to be 
delivered to a selected one of said message recipients; 

means for determining, by said IMS, whether said selected one is 
currently logged on to said IMS or another IMS; 

means for delivering said message to said selected one when said 
means for determining has a positive result; and 

means for forwarding said message on a particular alternative 
delivery mechanism associated with said recipient when said means for 
determining has a negative result and when said particular mechanism i; 
available . 



18. The system according to Claim 17, wherein said means for forward! 
further comprises: 

means for retrieving an associated entry from said registry usinc 
identifier of said selected one; and 

means for delivering said message to an address of said particula 
mechanism from said retrieved entry. 

19. The system according to Claim 18 , wherein said entry in said regi 
further comprises a constraint associated with each of said alternative 
message delivery mechanisms, each of said constraints specifying a 
condition for use of said associated mechanism, and wherein said means 
forwarding further comprises: 



means for iteratively evaluating each of said conditions from said 
retrieved entry until locating a match; and 
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means for using said mechanism associated with said matched condition 
as said particular mechanism. 
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20. The system according to Claim 19, further comprising means for 
rejecting said message when none of said conditions are met. 

21. The system according to Claim 17, further comprising: 

means for presenting available ones of said alternative delivery 
mechanisms to said sender when said means for determining has said negative 
result; 

means for enabling said sender to select from said presented ones; 

and 

wherein said means for forwarding uses said selected one as said 
particular mechanism. 

22. The system according to Claim 17, further comprising: 

means for receiving a multiple- recipient message from said sender, 
wherein said multiple -recipient message is to be delivered to more than one 
of said message recipients; and 

wherein: 

said means for determining whether said selected one is currently 
logged on determines whether each of said message recipients is currently 
logged on to said IMS; 

said means for delivering said message when said means for 
determining has said positive result delivers said message to each of said 
message recipients who is currently logged on; and 

when said means for determining has said negative result, said means 
for forwarding said message on said particular alternative delivery 
mechanism forwards said message to each of said message recipients who is 
not currently logged using an available mechanism associated with each of 
said not-logged-on message recipients. 

23. The system according to Claim 17, wherein said means for forwarding 
further comprises: 
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means for selecting an available one of said registered alternati 
delivery mechanisms associated with said recipient; and 

means for notifying said sender of said available one; and 

5 

wherein said means for forwarding further requires that said send|er 
accept said available one, 

24. A method for enabling an instant messaging system (IMS) to use 
10 alternative message delivery mechanisms in a computing environment, 

comprising the steps of: 

providing a registry comprising an entry for at least one of one 
more message recipients, wherein each of said entries comprises: (i) aln 
15 alternative message delivery mechanism, and (ii) addressing information for 

said alternative; 

receiving, from a message sender, a message to be delivered to a 
selected one of said message recipients; 

20 

determining, by said IMS, whether said selected one is currently 
logged on to said IMS or another IMS; 

delivering said message to said selected one when said determining 
25 step has a positive result; and 

forwarding said message on a particular alternative delivery 
mechanism associated with said recipient when said determining step has 
negative result and when said particular mechanism is available. 

30 

25. The method according to Claim 24 r wherein said forwarding step 
further comprises the steps of: 

retrieving an associated entry from said registry using an identifier. 
35 of said selected one; and 

delivering said message to an address of said particular mechanisfn 
from said retrieved, entry. 
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26. The method according to Claim 25, wherein said entry in said registry: 
further comprises a constraint associated with said alternative message 



delivery mechanism, said constraint specifying a condition for use of said 
associated mechanism, and wherein said forwarding step further comprises 
the steps of: 

verifying whether said condition from said retrieved entry is met; 

and 

determining that said particular mechanism is available only when 
said condition is met. 

27. The method according to Claim 26, further comprising the step of 
rejecting said message when said particular mechanism is not available. 

28. The method according to Claim 24, wherein said forwarding step 
further comprises the step of notifying said sender of said particular 
alternative, and wherein said forwarding step further requires that said 
sender accept said particular alternative. 

29. A method for enabling an instant messaging system (IMS) to use 
alternative message delivery mechanisms in a computing environment, 
comprising the steps of : 

providing a registry comprising an entry for at least one of one or 
more message recipients, wherein each of said entries comprises: (i) one 
or more alternative message delivery mechanisms, and (ii) addressing 
information for each of said alternatives; 

receiving, from a message sender, a message to be delivered to a 
selected one of said message recipients; 

determining, by said IMS, whether said selected one is currently 
logged on to said IMS or another IMS; 

delivering said message to said selected one when said determining 
step has a positive result; and 

forwarding said message on a particular alternative delivery 
mechanism associated with said recipient when said determining step has a 
negative result and when said particular mechanism is available. 
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30. The method according to Claim 29, wherein said forwarding step 
further comprises the steps of : 

retrieving an associated entry from said registry using an identifier 
5 of said selected one; and 

delivering said message to an address of said particular mechanis 
from said retrieved entry. 

10 31. The method according to Claim 30, wherein said entry in said registry 

further comprises a constraint associated with each of said alternative 
message delivery mechanisms, each of said constraints specifying a 
condition for use of said associated mechanism, and wherein said forwarding 
step further comprises the steps of; 

15 

iteratively evaluating each of said conditions from said retrieve^ 
entry until locating a match; and 

using said mechanism associated with said matched condition as sa[ld 
20 particular mechanism. 

32. The method according to Claim 31, further comprising the step of 
rejecting said message when none of said conditions are met. 

25 33. The method according to Claim 29, further comprising the steps of 

presenting available ones of said alternative delivery mechanisms to 
said sender when said determining step has said negative result; 

30 . enabling said sender to select from said presented ones; and 

wherein said forwarding step uses said selected one as said 
particular mechanism. 

35 34. The method according to Claim 29, further comprising the step of: 

receiving a multiple -recipient message from said sender, wherein ^aid 
multiple -recipient message is to be delivered to more than one of said 
message recipients; and 
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wherein : 



said determining whether said selected one is currently logged on 
step determines whether each of said message recipients is currently logged 
on to said IMS; 

said delivering said message when said determining step has said 
positive result step delivers said message to each of said message 
recipients who is currently logged on; and 

when said determining step has said negative result, said forwarding 
said message on said particular alternative delivery mechanism step 
forwards said message to each of said message recipients who is not 
currently logged using an available mechanism associated with each of said 
not-logged-on message recipients. 

35. The method according to Claim 29, wherein said forwarding step 
further comprises the steps of: 

selecting an available one of said registered alternative delivery 
mechanisms associated with said recipient; and 

notifying said sender of said available one; 

and wherein said forwarding step further requires that said sender 
accept said available one. 

36. A computer program embodied on a computer- readable medium in a 
computing environment for extending a wireless messaging system to enable 
use of registered message delivery mechanisms, comprising: 

a message sender; 

one or more message recipients; 

a registry comprising an entry for one or more of said message 
recipients, wherein each of said entries comprises: (i) a registered 
message delivery mechanism, and {ii) addressing information for said 
mechanism; 

computer-readable program code means for receiving, from said message 
sender, a message to be delivered to a selected one of said message 
recipients; 



computer- readable program code means for determining, by said 
extended messaging system, whether said selected one is currently available 
on said registered mechanisms- 



computer -readable program code means for delivering said message to 
said selected one on said available mechanism when said computer -readable 
program code means for determining has a positive result; and 

computer- readable program code means for notifying said sender thkt 
said message cannot be delivered when said computer- readable program coie 
means for determining has a negative result. 

37. A system in a computing environment for extending a wireless 
messaging system to enable use of registered message delivery mechanism 
comprising : 



a message sender; 



one or more message recipients; 



a registry comprising an entry for one or more of said message 
recipients, wherein each of said entries comprises: <i) one or more 
registered message delivery mechanisms, and (ii) addressing information for 
each of said mechanisms; 

means for receiving, from said message sender, a message to be 
delivered to a selected one of said message recipients; 

means for determining, by said extended messaging system, whether 
said selected one is currently logged on to an IMS; 

means for delivering said message to said selected one using said IMS 
when said means for determining has a positive result; and 

means for forwarding said message on a particular registered delivery 
mechanism associated with said recipient when said means for determininj 
has a negative result and when said particular mechanism is available. 

38. A method for extending a wireless messaging system to enable use Df 
registered message delivery mechanisms in a computing environment, 
comprising the steps of : 
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providing a registry comprising an entry for at least one of one or 
more message recipients, wherein each of said entries comprises: <i) one 
or more message delivery mechanisms, and (ii) addressing information for 
each of said alternatives; 

receiving, from a message sender, a message to be delivered to a 
selected one of said message recipients; 

determining, by said extended wireless messaging system, whether said 
selected one is currently logged on to an IMS; 

delivering said message to said selected one using said IMS when said 
determining step has a positive result; and 

forwarding said message on a particular registered delivery mechanism 
associated with said recipient when said determining step has a negative 
result and when said particular mechanism is available. 

39. A computer program embodied on a computer -readable medium in a 
computing environment for extending real-time awareness of users in a 
wireless messaging system, comprising: 

a first user; 

one or more other users; 

a registry comprising an entry for one or more of said other users, 
wherein each of said entries comprises: (i) a registered message delivery 
mechanism, and (ii) addressing information for said mechanism; 

computer- readable program code means for receiving, from said first 
user, a request for availability status information for a selected one of 
said other users; 

computer -readable program code means for determining, by said 
extended messaging system, whether said selected one is currently available 
on said registered mechanism; and 

computer- readable program code means for notifying said first user 
that said selected one is available when said computer -readable program 
code means for determining has a positive result. 
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40. A system in a computing environment for extending real-time awareness, 
of users in a wireless messaging system, comprising: 

a first user; 

5 

one or more other users; 

a registry comprising an entry for one or more of said other use: 
wherein each of said entries comprises: (i) one or more registered me: 
10 delivery mechanisms/ and (ii) addressing information for each of said 

mechanisms; 

means for receiving, from said first user, a request for availabi 
status information for a selected one of said other users; 

15 



means for determining, by said extended messaging system, whethei 
said selected one is currently available on any of said registered 
mechanisms; and 

20 means for notifying said first user that said selected one is 

available when said means for determining has a positive result. 

41. A method for extending real-time awareness of users in a wireless 
messaging system in a computing environment, comprising the steps of: 
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or 
ies 



providing a registry comprising an entry for at least one of one 
more users of said wireless messaging system, wherein each of said enti 
comprises: (i) one or more message delivery mechanisms, and (ii) 
addressing information for each of said alternatives; 

receiving, from a first user, a request for availability status 
information for a selected one of said registered users; 

determining, by said extended wireless messaging system, whether saicj 
35 selected one is currently available on any of said registered mechanisms 

and 

notifying said first user that said selected one is available whe|n 
said determining step has a positive result. 
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